package com.explorati.LeetCode704.search;

/**
 * @ Author : Weijian_Wang
 * @ Date : Created in 19:50 2020/9/13 0013
 * @ Description ：
 */
public class Solution {
    /**
     * 给定一个 n 个元素有序的（升序）整型数组 nums 和一个目标值 target  ，写一个函数搜索 nums 中的 target，如果目标值存在返回下标，否则返回 -1。
     * 输入: nums = [-1,0,3,5,9,12], target = 9
     * 输出: 4
     * 解释: 9 出现在 nums 中并且下标为 4
     * @param nums
     * @param target
     * @return
     */
    public int search(int[] nums, int target) {
        if(nums.length == 0) {
            return -1;
        }
        return search(nums, 0, nums.length, target);
    }

    private int search(int[] nums, int begin, int end, int target) {

        if(end - begin == 1) {
            if(nums[begin] == target) {
                return 0;
            }else {
                return -1;
            }
        }

        int mid = (begin + end) / 2;
        //nums是升序排列的
        if(nums[mid] > target) {
            return search(nums, begin, mid, target);
        }else if(nums[mid] < target) {
            return search(nums, mid, end, target);
        }else {
            return mid;
        }
    }

}
